<article id="wikiArticle">
<div></div>
<p>如果某个元素满足所提供的测试函数，<code><strong>findIndex()</strong></code>方法返回类型化数组中的 <strong>下标</strong>。否则返回 -1。 <em>TypedArray</em> 是这里的 <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/TypedArray#TypedArray_objects">类型化数组类型</a> 之一。</p>
<p>同时请参见<a href="Reference/Global_Objects/TypedArray/findIndex" title="如果某个元素满足所提供的测试函数，findIndex()方法返回类型化数组中的 下标。否则返回 -1。 TypedArray 是这里的 类型化数组类型 之一。"><code>find()</code></a>方法，它返回了类型化数组中所发现元素的 <strong>值</strong> ，而不是它的下标。</p>
<h2 id="语法">语法</h2>
<pre><code class="language-javascript"><code><var>typedarray</var>.findIndex(<var>callback</var>[, <var>thisArg</var>])</code></code></pre>
<h3 id="参数">参数</h3>
<dl>
<dt><code>callback</code></dt>
<dd>用于在类型化数组中的每个元素上执行的函数，接受三个参数：
 <dl>
<dt><code>element</code></dt>
<dd>要处理的类型化数组的当前元素。</dd>
<dt><code>index</code></dt>
<dd>要处理的当前元素在类型化数组中的下标</dd>
<dt><code>array</code></dt>
<dd><code>find</code> 在其上调用的类型化数组</dd>
</dl>
</dd>
<dt><code>thisArg</code></dt>
<dd>可选，执行<code>callback</code>时的<code>this</code>值。</dd>
</dl>
<h3 id="返回值">返回值</h3>
<p>如果元素通过了测试，则为数组下标，否则为 -1。</p>
<h2 id="描述">描述</h2>
<p><code>findIndex</code> 方法对类型化数组中的每个元素执行一次 <code>callback</code> 函数，直到它找到一个使 <code>callback</code> 返回 <em>true</em>的元素。如果发现了一个这样的元素，<code>find</code> 方法将会立即返回该元素的下标。否则，<code>findIndex</code> 方法会返回 -1。<code>callback</code> 只会对那些已经被赋值的索引调用。不会对那些被删除或从来没被赋值的索引调用。</p>
<p><code>callback</code> 以三个参数调用：元素的值，元素索引，以及要遍历的数组对象。</p>
<p>如果将<code>thisArg</code>参数提供给<code>findIndex</code>，它会在调用时传递给<code>callback</code>，作为它的 <code>this</code>值。如果没有提供，会使用<code>undefined</code>。</p>
<p><code>findIndex</code> 不修改在其上调用的类型化数组。</p>
<p>由 <code>findIndex</code>处理的元素范围在<code>callback</code>调用之前就确定了。 在 <code>findIndex</code>调用之后添加到数组的元素不会由 <code>callback</code>访问。 如果类型化数组的现有元素被改变，或被删除，它们传给<code>callback</code>的值是<code>findIndex</code> 访问它们时候的值。已删除的元素不会被访问。</p>
<h2 id="示例">示例</h2>
<h3 id="在类型化数组中寻找质数的下标">在类型化数组中寻找质数的下标</h3>
<p>下面的示例在类型化数组中寻找质数元素的下标（如果没有质数则返回 -1）.</p>
<pre><code  class="language-javascript">function isPrime(element, index, array) {
  var start = 2;
  while (start &lt;= Math.sqrt(element)) {
    if (element % start++ &lt; 1) {
      return false;
    }
  }
  return element &gt; 1;
}

var uint8 = new Uint8Array([4, 6, 8, 12]);
var uint16 = new Uint16Array([4, 6, 7, 12]);

console.log(uint8.findIndex(isPrime)); // -1, 未发现
console.log(uint16.findIndex(isPrime)); // 2
</code></pre>
<h2 id="Polyfill">Polyfill</h2>
<pre><code  class="language-javascript">TypedArray.prototype.findIndex = Array.prototype.findIndex = Array.prototype.findIndex || function(evaluator, thisArg) {
        'use strict';
        if (!this) {
          throw new TypeError('Array.prototype.some called on null or undefined');
        }
    
        if (typeof(evaluator) !== 'function') {
            if (typeof(evaluator) === 'string') {
                // 尝试将其转换为函数
                if ( ! (evaluator = eval(evaluator)) ){
                    throw new TypeError();
                }
            } else {
                throw new TypeError();
            }
        }
        
        var i;
        if (thisArg === undefined) {  // 为 thisArg 优化
            for (i in this) {
                if (evaluator(this[i], i, this)) {
                    return i;
                }
            }
            return -1;
        }
        for (i in this) {
            if (evaluator.call(thisArg, this[i], i, this)) {
                return i;
            }
        }
        return -1;
};</code></pre>
<h2 id="规范">规范</h2>
<table class="standard-table">
<tbody>
<tr>
<th scope="col">Specification</th>
<th scope="col">Status</th>
<th scope="col">Comment</th>
</tr>
<tr>
<td><a class="external" href="https://www.ecma-international.org/ecma-262/6.0/#sec-%typedarray%.prototype.findindex" hreflang="en" lang="en" rel="noopener">ECMAScript 2015 (6th Edition, ECMA-262)<br/><small lang="zh-CN">%TypedArray%.prototype.findIndex</small></a></td>
<td><span class="spec-Standard">Standard</span></td>
<td>初始定义。</td>
</tr>
<tr>
<td><a class="external" href="https://tc39.github.io/ecma262/#sec-%typedarray%.prototype.findindex" hreflang="en" lang="en" rel="noopener">ECMAScript Latest Draft (ECMA-262)<br/><small lang="zh-CN">%TypedArray%.prototype.findIndex</small></a></td>
<td><span class="spec-Draft">Draft</span></td>
<td> </td>
</tr>
</tbody>
</table>
<h2 id="浏览器兼容性">浏览器兼容性</h2>
<div><div class="blockIndicator warning"><strong><a class="external" href="https://github.com/mdn/browser-compat-data" rel="noopener">We're converting our compatibility data into a machine-readable JSON format</a></strong>.
            This compatibility table still uses the old format,
            because we haven't yet converted the data it contains.
            <strong><a class="new" href="/zh-CN/docs/MDN/Contribute/Structures/Compatibility_tables" rel="nofollow">Find out how you can help!</a></strong></div>
<div class="htab">
<a id="AutoCompatibilityTable" name="AutoCompatibilityTable"></a>
<ul>
<li class="selected"><a>Desktop</a></li>
<li><a>Mobile</a></li>
</ul>
</div></div>
<div id="compat-desktop">
<table class="compat-table">
<tbody>
<tr>
<th>Feature</th>
<th>Chrome</th>
<th>Firefox (Gecko)</th>
<th>Internet Explorer</th>
<th>Opera</th>
<th>Safari</th>
</tr>
<tr>
<td>Basic support</td>
<td><span style="color: #f00;">未实现</span></td>
<td><a href="/en-US/Firefox/Releases/37" title="Released on 2015-04-07.">37.0</a> (37.0)</td>
<td><span style="color: #f00;">未实现</span></td>
<td><span style="color: #f00;">未实现</span></td>
<td><span style="color: #f00;">未实现</span></td>
</tr>
</tbody>
</table>
</div>
<div id="compat-mobile">
<table class="compat-table">
<tbody>
<tr>
<th>Feature</th>
<th>Android</th>
<th>Chrome for Android</th>
<th>Firefox Mobile (Gecko)</th>
<th>IE Mobile</th>
<th>Opera Mobile</th>
<th>Safari Mobile</th>
</tr>
<tr>
<td>Basic support</td>
<td><span style="color: #f00;">未实现</span></td>
<td><span style="color: #f00;">未实现</span></td>
<td>37.0 (37.0)</td>
<td><span style="color: #f00;">未实现</span></td>
<td><span style="color: #f00;">未实现</span></td>
<td><span style="color: #f00;">未实现</span></td>
</tr>
</tbody>
</table>
</div>
<h2 id="另见">另见</h2>
<ul>
<li><a href="Reference/Global_Objects/TypedArray/find" title="如果某个元素满足所提供的测试函数，find()方法返回类型化数组中的 值。否则返回undefined 。 TypedArray 是这里的 类型化数组类型 之一。"><code>TypedArray.prototype.find()</code></a></li>
<li><a href="Reference/Global_Objects/TypedArray/indexOf" title="indexOf() 方法返回在类型数组中可以找到给定元素的第一个索引，如果不存在，则返回-1。 方法具有与 Array.prototype.indexOf() 相同的算法。 TypedArray是这里的类型化数组类型之一。"><code>TypedArray.prototype.indexOf()</code></a></li>
</ul>
</article>